package com.echo.servlet;

import java.sql.Connection;
import java.sql.SQLException;

import com.mchange.v2.c3p0.ComboPooledDataSource;
import com.mchange.v2.c3p0.DataSources;

public class ConnectionManager1 {
	  private static ConnectionManager1 instance;

      private ComboPooledDataSource ds;


      private ConnectionManager1() throws Exception {
          
          ds = new ComboPooledDataSource();


          ds.setDriverClass("com.mysql.jdbc.Driver");
          ds.setJdbcUrl("jdbc:mysql://192.168.3.122:3306/echo_school");
          ds.setUser("root");
          ds.setPassword("123456");
          ds.setInitialPoolSize(3);//初始化时获取三个连接，取值应在minPoolSize与maxPoolSize之间。Default: 3 initialPoolSize
          ds.setMaxPoolSize(10);//连接池中保留的最大连接数。Default: 15 maxPoolSize
          ds.setMinPoolSize(1);// 连接池中保留的最小连接数。
          ds.setAcquireIncrement(1);//当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。Default: 3 acquireIncrement
          ds.setIdleConnectionTestPeriod(60);//每60秒检查所有连接池中的空闲连接。Default: 0  idleConnectionTestPeriod
          ds.setMaxIdleTime(25000);  //最大空闲时间,25000秒内未使用则连接被丢弃。若为0则永不丢弃。Default: 0  maxIdleTime
          ds.setAutoCommitOnClose(true); //连接关闭时默认将所有未提交的操作回滚。Default: false autoCommitOnClose
          
          /**
           * 注释------------------------------------------------------------------------
           */
          //定义所有连接测试都执行的测试语句。在使用连接测试的情况下这个一显著提高测试速度。注意：
          //测试的表必须在初始数据源的时候就存在。Default: null  preferredTestQuery
          //ds.setPreferredTestQuery("select sysdate from dual");
          // 因性能消耗大请只在需要的时候使用它。如果设为true那么在每个connection提交的
          // 时候都将校验其有效性。建议使用idleConnectionTestPeriod或automaticTestTable
          // 等方法来提升连接测试的性能。Default: false testConnectionOnCheckout
          /**
           * 注释------------------------------------------------------------------------
           */
          
          ds.setTestConnectionOnCheckout(true);
          //如果设为true那么在取得连接的同时将校验连接的有效性。Default: false  testConnectionOnCheckin
          ds.setTestConnectionOnCheckin(true);
          
          ds.setAcquireRetryAttempts(10);//定义在从数据库获取新连接失败后重复尝试的次数。Default: 30  acquireRetryAttempts
          
          ds.setAcquireRetryDelay(1000);//两次连接中间隔时间，单位毫秒。Default: 1000 acquireRetryDelay
          //获取连接失败将会引起所有等待连接池来获取连接的线程抛出异常。但是数据源仍有效
          //保留，并在下次调用getConnection()的时候继续尝试获取连接。如果设为true，那么在尝试
          //获取连接失败后该数据源将申明已断开并永久关闭。Default: false  breakAfterAcquireFailure
          ds.setBreakAfterAcquireFailure(true);
         
      }


      public static final ConnectionManager1 getInstance() {
          if (instance == null) {
              try {
                  instance = new ConnectionManager1();
              } catch (Exception e) {
                  e.printStackTrace();
              }
          }
          return instance;
      }


      public synchronized final Connection getConnection() {
          try {
              return ds.getConnection();
          } catch (SQLException e) {
              e.printStackTrace();
          }
          return null;
      }


      protected void finalize() throws Throwable {
          DataSources.destroy(ds); //关闭datasource
          super.finalize();
      }

}
